{{!
  Copyright (c) HashiCorp, Inc.
  SPDX-License-Identifier: BUSL-1.1
}}

<PageHeader as |p|>
  <p.top>
    <KeyValueHeader
      @baseKey={{this.baseKey}}
      @path="vault.cluster.access.leases.list"
      @root={{this.backendCrumb}}
      @showCurrent={{true}}
      @linkToPaths={{this.capabilities.leases.canList}}
    />
  </p.top>
  <p.levelLeft>
    <h1 class="title is-3">
      <LinkTo @route="vault.cluster.access.leases">
        Leases
      </LinkTo>
    </h1>
  </p.levelLeft>
</PageHeader>

{{#if this.capabilities.revoke.canUpdate}}
  <Toolbar>
    <ToolbarActions>
      <ConfirmAction
        @buttonText="Revoke lease"
        class="toolbar-button"
        @buttonColor="secondary"
        @confirmTitle="Revoke this?"
        @confirmMessage="All leases under this one will also be removed."
        @onConfirmAction={{action "revokeLease" this.model}}
        data-test-lease-revoke
      />
    </ToolbarActions>
  </Toolbar>
{{/if}}

<div class="field box is-fullwidth is-sideless is-paddingless is-marginless">
  <InfoTableRow @label="Issue time" @value={{this.model.issueTime}}>
    {{date-format this.model.issueTime "MMM dd, yyyy hh:mm:ss a"}}
    <br />
    <code>
      {{this.model.issueTime}}
    </code>
  </InfoTableRow>
  <InfoTableRow @label="Renewable" @value={{this.model.renewable}} />
  <InfoTableRow @label="Last renewal" @value={{this.model.lastRenewal}}>
    {{date-format this.model.lastRenewal "MMM dd, yyyy hh:mm:ss a"}}
    <br />
    <code>
      {{this.model.lastRenewal}}
    </code>
  </InfoTableRow>
  {{#if this.model.expireTime}}
    <InfoTableRow @label="Expiration time" @value={{this.model.expireTime}}>
      {{date-format this.model.expireTime "MMM dd, yyyy hh:mm:ss a"}}
      <br />
      <code>
        {{this.model.expireTime}}
      </code>
    </InfoTableRow>
    <InfoTableRow @label="Expires in" @value={{date-from-now this.model.expireTime increment=1000 hideSuffix=true}} />
  {{/if}}
  <InfoTableRow @label="TTL" @value={{this.model.ttl}} />
</div>
{{#if (and (not this.model.isAuthLease) this.model.renewable this.capabilities.renew.canUpdate)}}
  <div class="box is-shadowless" data-test-lease-renew-picker={{true}}>
    <h2 class="title is-6">Renew Lease</h2>
    <form {{action "renewLease" this.model this.increment on="submit"}}>
      <TtlPicker
        @label="Increment"
        @helperTextEnabled="Lease will expire after"
        @helperTextDisabled="Vault will use the default lease duration"
        @labelClass="is-label"
        @onChange={{action (mut this.increment)}}
        @unit="s"
      />
      <div class="field has-top-margin-s">
        <div class="control">
          <Hds::Button @text="Renew lease" type="submit" />
        </div>
      </div>
    </form>
  </div>
{{/if}}